<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <!-- computed和watch区别：
       1、computed能实现的功能，watch都可以实现
       2、watch能实现的功能,computed不一定能实现，watch里面可以实现异步操作
  -->

  <!-- 准备好一个容器-->
  <div id="app">
    姓：<input type="text" v-model="firstName"/><br/>
    名：<input type="text" v-model="lastName"/><br/>
    全名：<span>{{fullName}}</span><br/>
  </div>
  <script src="vue.js"></script>
  <script>
    Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。
    //创建vue实例
    new Vue({
      el: '#app',
      data: {
        firstName: '张',
        lastName: '三',
        fullName: '张-三'
      },
      watch: {
        firstName(newValue, oldValue) {
          /*setTimeout(function() {

          }, 1000);*/
          setTimeout(() => {
            console.log(newValue, oldValue);
            this.fullName = newValue + '-' + this.lastName;
          }, 2000);
          
        },
        lastName(newVlaue) {
          this.fullName = this.firstName + '-' + newVlaue;
        }
      }
    })
  </script>
</body>

</html>